home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Gekikoh Dennoh Club 2
/
Gekikoh Dennoh Club Vol. 2 (Japan).7z
/
Gekikoh Dennoh Club Vol. 2 (Japan) (Track 01).bin
/
fsw
/
zm302
/
zm302_s.lzh
/
MPSRC045.LZH
/
P8_LOW.HAS
< prev
next >
Wrap
Text File
|
1996-11-18
|
4KB
|
149 lines
*=======================================================
*
* 8bitPCM低音程変換
*
*=======================================================
PCM8_low:
move.w CH_PITCH+2(a5),d3 * d3.w = PCM音程
move.w CH_VOL(a5),d5 * d5.w = PCM VOLUME
tst.b CH_KEY_STAT(a5) * keyon=$01 keyoff=$80 non=$00
bmi PCM8_low_keyoff
bne PCM8_low_keyon
* 通常の処理
move.w CH_LAST_PCM(a5),d0 * d0.w = 前回変換終了時のPCM値
move.w CH_PITCH_CTR(a5),d4 * d4.w = 音程カウンタ
movea.l CH_PCM_ADR(a5),a0 * a0.l = PCMアドレス
movea.l CH_TRAP_ADR(a5),a3 * a3.l = トラップアドレス
movea.l CH_TRAP_ROUTINE(a5),a4 * a4.l = トラップ時の処理ルーチン
movea.l CH_JMP_ADR2(a5),a6
jmp (a6)
* キーオンの処理
PCM8_low_keyon:
clr.b CH_KEY_STAT(a5) * KEY 状態リセット
moveq.l #0,d0 * d0.w = PCM予測値
move.w d3,d4 * d4.w = 音程カウンタ
neg.w d4 * d4.w =-増分(1回目でPCM変換するため)
movea.l CH_TOP_ADR(a5),a0 * a0.l = PCM先頭アドレス
move.l CH_LPTIME(a5),d7 * ループ処理があるか?
moveq.l #1,d1
cmp.l d1,d7 * cmpi.l より4clk 速い
beq 1f
move.l d7,CH_LPTIME_CTR(a5) * ループ回数カウンタ初期化
movea.l CH_LPEND_ADR(a5),a3 * a3.l = ループ終了アドレス
lea.l PCM8_LPEND,a4 * a4.l = ループ終了処理アドレス
move.l a3,CH_TRAP_ADR(a5)
move.l a4,CH_TRAP_ROUTINE(a5) * トラップ情報ををワークに保存
movea.l CH_JMP_ADR2(a5),a6
jmp (a6)
1: movea.l CH_END_ADR(a5),a3 * a3.l = 16bit PCMデータ終了アドレス
lea.l PCM8_END,a4 * a4.l = データ終了処理アドレス
move.l a3,CH_TRAP_ADR(a5)
move.l a4,CH_TRAP_ROUTINE(a5) * トラップ情報ををワークに保存
movea.l CH_JMP_ADR2(a5),a6
jmp (a6)
* キーオフの処理
PCM8_low_keyoff:
clr.b CH_KEY_STAT(a5) * KEY 状態リセット
clr.b CH_PLAY_FLAG(a5) * 演奏終了
jmp make_keyoff_PCM * 消音PCM展開
*=======================================================
PCM8_low_mac macro _vol
move.l CH_TPCNST(a5),d6
add.l a0,d6
cmp.l a3,d6
bcs @f
* トラップあり
moveq.l #MIX_SIZE*2-1,d6
3: add.w d3,d4 * 音程カウンタ += 音程
bcc 2f
cmpa.l a3,a0 * データ終わった?
bcs 1f
jsr (a4) * トラップ!
1: move.b (a0)+,d0 * PCMデータ取り込み
ext.w d0 * 符号拡張
2: .if _vol=8
add.w d0,(a1)+
.else
move.w d0,d1
VOLUME _vol,d1,d7
add.w d1,(a1)+
.endif
dbra d6,3b
move.w d0,CH_LAST_PCM(a5) * d0.w = 前回変換終了時のPCM値
.if _vol=8
move.w d0,CH_LAST_VPCM(a5) * 最後のPCM値(音量変換後)
.else
move.w d1,CH_LAST_VPCM(a5) * 最後のPCM値(音量変換後)
.endif
move.w d4,CH_PITCH_CTR(a5) * d4.w = 音程カウンタ
move.l a0,CH_PCM_ADR(a5) * a0.l = PCMアドレス
rts
* トラップ無しの変換
@@: moveq.l #MIX_SIZE*2-1,d6
3: add.w d3,d4 * 音程カウンタ += 音程
bcc 2f
move.b (a0)+,d0 * PCMデータ取り込み
ext.w d0 * 符号拡張
2: .if _vol=8
add.w d0,(a1)+
.else
move.w d0,d1
VOLUME _vol,d1,d7
add.w d1,(a1)+
.endif
dbra d6,3b
move.w d0,CH_LAST_PCM(a5) * 変換終了時のPCM値
.if _vol=8
move.w d0,CH_LAST_VPCM(a5) * 最後のPCM値(音量変換後)
.else
move.w d1,CH_LAST_VPCM(a5) * 最後のPCM値(音量変換後)
.endif
move.w d4,CH_PITCH_CTR(a5) * d4.w = 音程カウンタ
move.l a0,CH_PCM_ADR(a5) * a0.l = PCMアドレス
rts
endm
*=======================================================
PCM8_low_v00: PCM8_low_mac 0
PCM8_low_v01: PCM8_low_mac 1
PCM8_low_v02: PCM8_low_mac 2
PCM8_low_v03: PCM8_low_mac 3
PCM8_low_v04: PCM8_low_mac 4
PCM8_low_v05: PCM8_low_mac 5
PCM8_low_v06: PCM8_low_mac 6
PCM8_low_v07: PCM8_low_mac 7
PCM8_low_v08: PCM8_low_mac 8
PCM8_low_v09: PCM8_low_mac 9
PCM8_low_v10: PCM8_low_mac 10
PCM8_low_v11: PCM8_low_mac 11
PCM8_low_v12: PCM8_low_mac 12
PCM8_low_v13: PCM8_low_mac 13
PCM8_low_v14: PCM8_low_mac 14
PCM8_low_v15: PCM8_low_mac 15
PCM8_low_vnn: PCM8_low_mac 'n'
PCM8_low_non: PCM8_low_mac 'x'